package proyecto.dao;

import java.sql.*;
import java.util.ArrayList;
import java.util.Collection;
import proyecto.modelo.Tipo;

public class TipoDAO {

    public Tipo insertar(Tipo ti) {
        String query = "INSERT INTO tipo(nombretipo)" + "VALUES (?)";
        System.err.println(query);
        Connection con = null;
        PreparedStatement stmt = null;
        try {
            con = ConexionBD.obtenerConexion();
            stmt = con.prepareStatement(query);
            stmt.setString(1, ti.getNombre());
            int i = stmt.executeUpdate();
            if (i != 1) {
                throw new SQLException("No se pudo insertar");
            }
            stmt.close();
            con.close();
        } catch (SQLException e) {
            System.err.println(e.getMessage());
        }
        return ti;
    }

    public Collection<String> listar() {
        String query = "SELECT nombretipo FROM tipo";
        Collection<String> tipos = new ArrayList<String>();
        try {
            Connection con = ConexionBD.obtenerConexion();
            Statement stmt = con.createStatement();
            ResultSet rs = stmt.executeQuery(query);
            while (rs.next()) {
                tipos.add(rs.getString("nombretipo"));
            }
            rs.close();
            stmt.close();
            con.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return tipos;
    }

    public Collection<Integer> listarID(){
        String query = "SELECT idtipo FROM tipo";
        Collection<Integer> clases = new ArrayList<Integer>();
        try {
            Connection con = ConexionBD.obtenerConexion();
            Statement stmt = con.createStatement();
            ResultSet rs = stmt.executeQuery(query);
            while (rs.next()) {
                clases.add(rs.getInt("idtipo"));
            }
            rs.close();
            stmt.close();
            con.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return clases;
    }

    public Tipo modificar(Tipo ti) {
        String query = "UPDATE tipo SET nombretipo = ? WHERE idtipo = ?";
        System.err.println(query);
        Connection con = null;
        PreparedStatement stmt = null;
        try {
            con = ConexionBD.obtenerConexion();
            stmt = con.prepareStatement(query);
            stmt.setString(1, ti.getNombre());
            stmt.setInt(2, ti.getIdtipo());
            int i = stmt.executeUpdate();
            if (i != 1) {
                throw new SQLException("No se pudo modificar");
            }
            stmt.close();
            con.close();
        } catch (SQLException e) {
            System.err.println(e.getMessage());
        }
        return ti;
    }

    public Tipo eliminar(Tipo ti) {
        String query = "DELETE FROM tipo WHERE idtipo = ?";
        System.err.println(query);
        Connection con = null;
        PreparedStatement stmt = null;
        try {
            con = ConexionBD.obtenerConexion();
            stmt = con.prepareStatement(query);
            stmt.setInt(1, ti.getIdtipo());
            int i = stmt.executeUpdate();
            if (i != 1) {
                throw new SQLException("No se pudo eliminar");
            }
            stmt.close();
            con.close();
        } catch (SQLException e) {
            System.err.println(e.getMessage());
        }
        return ti;
    }
}
